#include<bits/stdc++.h>
using namespace std;
int a[100005]={0},b[100015]={0};
void prime(int n){
	b[0]=1;
	b[1]=1;
	for(int i=2;i<n;i++){
		if(!b[i]) a[++a[0]]=i;
		for(int j=1;j<=a[0]&&a[j]*i<n;j++){
			b[a[j]*i]=1;
			if(i%a[j]==0) break;
		}
	}
}
int main(){
	prime(100013);
	int m,n,x[505][505]={0};
	scanf("%d%d",&m,&n);
	for(int i=1;i<=m;i++){
		for(int j=1;j<=n;j++){
			scanf("%d",&x[i][j]);
			int k=0;
			while(x[i][j]>a[++k]);
			x[i][j]=a[k]-x[i][j];
			x[i][n+1]+=x[i][j];
			x[m+1][j]+=x[i][j];			
		}
	}
	int minx,ans=0;
	minx=x[m+1][1];
	for(int i=1;i<=m||i<=n;i++){
		if(i<=m) minx=min(minx,x[i][n+1]);
		if(i<=n) minx=min(minx,x[m+1][i]);
	}
	printf("%d",minx);
	return 0;
}
